# Unité de transmission/réception série asynchrone – version sans bit de parité

Programmation en VHDL : Informatique et Mathématiques Appliquées – Parcours Logiciel

## Plan de la présentation

#### 1 Introduction

- L'UART
- La liaison RS232

### 2 Description de l'UART à réaliser (1ère partie)

- Description du projet
- Gestion des horloges d'émission et de réception
- L'unité de contrôle de l'UART (fournie)
- L'unité d'émission

L'UART

## Plan de la présentation

### 1 Introduction

- L'UART
- La liaison RS232

## 2 Description de l'UART à réaliser (1ère partie)

- Description du projet
- Gestion des horloges d'émission et de réception
- L'unité de contrôle de l'UART (fournie)
- L'unité d'émission

Introduction L'UART

## UART : Universal Asynchronous Receiver Transmitter

- contrôleur d'entrée/sortie pour le mode RS232
- RS232 : liaison série point à point utilisée pour connecter des modems, des souris, ...
- remplacé par le bus USB
- Plusieurs modèles :
  - 8250 : registres de 8 bits
  - 16450 : registres de 16 bits
  - 16550 : registres de 16 bits + utilisation de FIFOs

La liaison RS232

# Plan de la présentation

### 1 Introduction

- L'UART
- La liaison RS232

## 2 Description de l'UART à réaliser (1ère partie)

- Description du projet
- Gestion des horloges d'émission et de réception
- L'unité de contrôle de l'UART (fournie)
- L'unité d'émission

La liaison RS232

## La liaison RS232, ça me dit quelque chose ...

■ Jamais entendu parlé?





■ Où ça se branche?



## La liaison RS232, qu'est-ce que c'est?

- Transmission série bidirectionnelle (half-duplex ou full-duplex)
- Transmission asynchrone → délimiteurs
  - 1 bit de start
  - 1, 1.5, ou 2 bits de stop
- Détection d'erreur : bit de parité

Exemple de transmission RS232



## La liaison RS232, comment ça marche?

- Transmission orientée bit
- Resynchronisation du récepteur à la réception du bit de Start
- Contrôle de flux :
  - logiciel : caractère XON (0x11) = prêt à recevoir, caractère XOFF (0x13) = demande de suspension de la réception
  - matériel : 2 fils supplémentaires : l'émetteur désire émettre (RTS - Ready to Send), le récepteur est prêt à recevoir (CTS - Clear to Send)



## La liaison RS232, les signaux transmis

## Niveaux électriques

- 1 logique → tension comprise entre -3V et -25V
- lacksquare 0 logique ightarrow tension comprise entre +3V et +25V
- ex : transmission de 45 (en hexadécimal) avec 1 bit de stop et sans parité



La liaison RS232

# La liaison RS232, gestion de l'asynchronisme

■ chez l'émetteur, fréquence d'émission 9,6 kHz :



■ chez le récepteur :



La liaison RS232

# La liaison RS232, gestion de l'asynchronisme (suite)

mais dérive des horloges :



La liaison RS232

# La liaison RS232, gestion de l'asynchronisme (suite)

### ■ le cas pire :



La liaison RS232

# La liaison RS232, gestion de l'asynchronisme (fin)

la solution : détecter au plus tôt le changement de la ligne par surréchantillonnage à la réception



■ fréquence de réception = 155 kHz, soit 16x la fréquence d'émission

Description du projet

# Plan de la présentation

### 1 Introduction

- L'UART
- La liaison RS232

## 2 Description de l'UART à réaliser (1ère partie)

- Description du projet
- Gestion des horloges d'émission et de réception
- L'unité de contrôle de l'UART (fournie)
- L'unité d'émission

Description du projet

## Schéma en global de l'UART



```
L'interface en VHDL :
entity UART is
  port (
    clk, reset : in std_logic;
    cs. rd. wr :
                 in std_logic:
    RxD
                 in
                     std_logic;
    TxD
                 out std_logic;
    IntR
               : out std_logic:
    IntT
               : out std_logic;
              : in std_logic_vector(1 downto 0);
    addr
    data_in : in std_logic_vector(7 downto 0);
    data_out
               : out std_logic_vector(7 downto 0));
end UART:
```

Description du projet

## L'UART à réaliser

- Pour simplifier, l'horloge du circuit a une fréquence de 155 kHz (horloge de réception)
- Le système se découpe en 4 unités :
  - unité de gestion des horloges d'émission et de réception, clkUnit
  - unité de contrôle qui gère le registre de contrôle
  - unité d'émission
  - unité de réception

Description du projet

## Schéma interne de l'UART



Description du projet

## Schéma interne de l'UART



Gestion des horloges d'émission et de réception

# Plan de la présentation

- 1 Introduction
  - L'UART
  - La liaison RS232
- 2 Description de l'UART à réaliser (1ère partie)
  - Description du projet
  - Gestion des horloges d'émission et de réception
  - L'unité de contrôle de l'UART (fournie)
  - L'unité d'émission

- Description de l'UART à réaliser (1ère partie)
- Gestion des horloges d'émission et de réception

## L'interface de l'unité de gestion des horloges



```
entity clkUnit is

port (
    clk, reset : in std_logic;
    enableTX : out std_logic;
    enableRX : out std_logic);
end clkUnit:
```

## Implantation de cette unité

- Génère 2 horloges :
  - enableRX, horloge de réception, de fréquence 155 kHz
    - pour simplifier, enableRX est synchrone avec l'horloge du circuit : enableRX = clk
  - enableTX, horloge d'émission, de fréquence 9,6 kHz, 16x moins rapide que clk

<sup>-</sup> Description de l'UART à réaliser (1ère partie)

Gestion des horloges d'émission et de réception

# Le comportement de l'unité de gestion des horloges



- tant que reset=0, les horloges enableRX et enableTX n'évoluent pas
- enableRX est une copie de l'horloge clk
- au bout de 16 tops d'horloge clk, enableTX passe à 1

<sup>-</sup> Description de l'UART à réaliser (1ère partie)

Gestion des horloges d'émission et de réception

Gestion des horloges d'émission et de réception

## Travail à effectuer

■ Construire l'unité de gestion des horloges

L'unité de contrôle de l'UART (fournie)

# Plan de la présentation

### 1 Introduction

- L'UART
- La liaison RS232

## 2 Description de l'UART à réaliser (1ère partie)

- Description du projet
- Gestion des horloges d'émission et de réception
- L'unité de contrôle de l'UART (fournie)
- L'unité d'émission

## Rôle de l'unité de contrôle (1)

- Fournir les signaux d'interruption IntR et IntT au processeur
  - lorsqu'une donnée a été reçue par l'unité de réception, un front descendant sur IntR indique au processeur qu'il peut demander la lecture de l'octet présent dans le registre de réception
  - lorsque l'unité d'émission est disponible, un front descendant sur IntT indique au processeur qu'il peut émettre un nouvel octet

<sup>-</sup> Description de l'UART à réaliser (1ère partie)

L'unité de contrôle de l'UART (fournie)

L'unité de contrôle de l'UART (fournie)

# Rôle de l'unité de contrôle (2)

- Gérer le registre de contrôle ctrlReg en utilisant les signaux fournit par les unités d'émission et de réception
  - le processeur pourra lire ce registre en position addr=01 et en envoyant un signal de lecture (i.e. sélection de l'UART par cs et commande lecture rd)

- TxRdy: l'UART est prête à émettre
- RxRdy: l'UART est prête recevoir

- FErr : la trame transmise est erronée
- OErr : le processeur n'a pas lu à temps la donnée reçue

L'unité de contrôle de l'UART (fournie)

## Interface de l'unité de contrôle



```
entity ctrlUnit is
  port (
    clk, reset
                      in std_logic;
   rd, wr
                      in std_logic;
   DRdy, FErr, OErr: in std_logic;
   BufE, RegE
                    : in std_logic;
                   : out std_logic;
    IntR
    IntT
                    : out std_logic:
    ctrlRea
                    : out std_logic_vector(7 downto 0));
end ctrlUnit;
```

L'unité d'émission

# Plan de la présentation

### 1 Introduction

- L'UART
- La liaison RS232

## 2 Description de l'UART à réaliser (1ère partie)

- Description du projet
- Gestion des horloges d'émission et de réception
- L'unité de contrôle de l'UART (fournie)
- L'unité d'émission

L'unité d'émission

## Interface de l'unité d'émission



```
entity TXUnit is
  port (
    clk, reset : in std_logic;
    enable
              : in std_logic;
    ld
               : in std_logic;
               : out std_logic;
    txd
    regE
               : out std_logic;
    bufE
               : out std_logic:
               : in std_logic_vector(7 downto 0)
    data
end TXUnit;
```

L'unité d'émission

## Composants de l'unité d'émission



## L'émetteur se compose de :

- un registre BufferE qui permet de mettre en attente une nouvelle donnée lorsqu'une donnée est en train d'être émise. Le signal BufE permet de savoir si le buffer est vide (BufE=1) ou pas (BufE=0)
- un registre RegisterE, registre d'émission utilisé par le circuit contrôle d'émission au cours de la transmission de la donnée. Le signal RegE permet de savoir si ce registre est vide (RegE=1)ou pas (RegE=0)
- un circuit de contrôle d'émission qui positionne les bits à émettre sur la ligne TxD à chaque top de enableTX

L'unité d'émission

## Fonctionnement de l'unité d'émission

initialement le buffer et le registre sont libres (bufE=1 et regE=1)



L'unité d'émission

- initialement le buffer et le registre sont libres (bufE=1 et regE=1)
- chargement d'une donnée dans le buffer (bufE=0 et regE=1)



L'unité d'émission

- initialement le buffer et le registre sont libres (bufE=1 et regE=1)
- 2 chargement d'une donnée dans le buffer (bufE=0 et regE=1)
- 3 déchargement du buffer dans le registre d'émission (bufE=1 et regE=0), le buffer est libre → le processeur peut émettre un nouveau caractère



L'unité d'émission

- initialement le buffer et le registre sont libres (bufE=1 et regE=1)
- chargement d'une donnée dans le buffer (bufE=0 et regE=1)
- 3 déchargement du buffer dans le registre d'émission (bufE=1 et regE=0), le buffer est libre → le processeur peut émettre un nouveau caractère
- 4 envoi du bit de start



L'unité d'émission

- initialement le buffer et le registre sont libres (bufE=1 et regE=1)
- chargement d'une donnée dans le buffer (bufE=0 et regE=1)
- 3 déchargement du buffer dans le registre d'émission (bufE=1 et regE=0), le buffer est libre → le processeur peut émettre un nouveau caractère
- 4 envoi du bit de start
- 5 envoi des données



L'unité d'émission

- initialement le buffer et le registre sont libres (bufE=1 et regE=1)
- chargement d'une donnée dans le buffer (bufE=0 et regE=1)
- 3 déchargement du buffer dans le registre d'émission (bufE=1 et regE=0), le buffer est libre → le processeur peut émettre un nouveau caractère
- 4 envoi du bit de start
- 5 envoi des données
- envoi du bit de stop, le registre est libre à nouveau (bufE=1 et regE=1)



L'unité d'émission

## Test de l'unité d'émission

■ Emission d'un unique caractère 0x55 ('U') :



L'unité d'émission

## Test de l'unité d'émission

#### Emission de 2 caractères à la suite :

■ Emission du caractère 0xAA et acquisition du caractère 0x45 ('E') :



L'unité d'émission

## Test de l'unité d'émission

#### Emission de 2 caractères à la suite :

■ 2 derniers bits du caractère 0xAA et émission du caractère 0x45 :

